# 5.3. A very simple computer (DIDACOMP)



### **DidaComp**

In a new project, **P29\_DIDACOMP\_ControlUnit**. Add a VHDL file describing the control unit, "**ControlUnit\_0**". Add a **testbench** to check the right performance.

Make sure you add the internal signal "NextState" when you launch the simulator. That signal shows the different states of the FSM for each clock cycle.



### **DidaComp**

In a new project, P30\_DIDACOMP\_SIM. Add a VHDL file to describe DIDACOMP in a structural way. DIDACOMP is the connection between the DATAPATH\_0 and ControlUnit\_0. Add a testbench to check the right performance.



In a new project, **P31\_DIDACOMP\_Nexys**, add a new VHDL file, "DIDACOMP\_Nexys4". It is consists of *uArq* and *ControlUnit\_0*.

Some **modifications** must be done to see a right performance onto Nexys4:

- 1. In the file "ControlUnit\_0" (make sure it is located as local), add a input called "PUSH\_i".
- 2. Add it to the file "DIDACOMP\_Nexys4" also and connect it as necessary.



3. Modify the VHDL code to add the input "PUSH\_i" in such only when it is pressed, the FSM changes.

```
if (PUSH i = '1') then

case NEXT_STATE is
-- State "IDLE"
    when IDLE=>
        NEXT_STATE <= LOAD;
-- State "LOAD"
    when LOAD=>
        NEXT_STATE <= DECO;
-- State "DECO"
    when DECO=>
```



4. Modify Didacomp to add two "EDGE\_DETECTOR" modules (P14) to turn into pulses the CW\_o(6) and CW\_o(4), REG\_PC and REG\_INST respectively.





- 5. Add "DEBOUNCE" (P27) module to avoid the bouncing in the pushbutton which controls "PUSH\_i".
- 6. As usual, connect the "DISP7SEG\_8ON" module to monitor the ports in DIDACOMP
- 7. Do not forget assign the signals INST and FZ to the ports INST\_o and FZ\_o (LEDs in board)





- Finally, add the constraints file and generate the bitstream. Connect the LED for showing the instructions and FZ, ANODE and CATHODE, and one pushbutton for RST\_i and another one to PUSH\_i.
- Download the bitstream and verify the right performance of DIDACOMP in Nexys4.

